#include <dis6/GridAxisRecordRepresentation0.h>

using namespace DIS;

GridAxisRecordRepresentation0::GridAxisRecordRepresentation0()
    : GridAxisRecord(), _numberOfBytes(0) {}

GridAxisRecordRepresentation0::~GridAxisRecordRepresentation0() {
  _dataValues.clear();
}

unsigned short GridAxisRecordRepresentation0::getNumberOfBytes() const {
  return _dataValues.size();
}

std::vector<uint8_t> &GridAxisRecordRepresentation0::getDataValues() {
  return _dataValues;
}

const std::vector<uint8_t> &
GridAxisRecordRepresentation0::getDataValues() const {
  return _dataValues;
}

void GridAxisRecordRepresentation0::setDataValues(
    const std::vector<uint8_t> &pX) {
  _dataValues = pX;
}

void GridAxisRecordRepresentation0::marshal(DataStream &dataStream) const {
  GridAxisRecord::marshal(
      dataStream); // Marshal information in superclass first
  dataStream << (unsigned short)_dataValues.size();

  for (auto &byte : _dataValues) {
    dataStream << byte;
  }
}

void GridAxisRecordRepresentation0::unmarshal(DataStream &dataStream) {
  GridAxisRecord::unmarshal(
      dataStream); // unmarshal information in superclass first
  dataStream >> _numberOfBytes;

  _dataValues.clear();
  for (auto idx = 0; idx < _numberOfBytes; ++idx) {
    uint8_t x;
    dataStream >> x;
    _dataValues.push_back(x);
  }
}

bool GridAxisRecordRepresentation0::operator==(
    const GridAxisRecordRepresentation0 &rhs) const {
  auto ivarsEqual = true;

  ivarsEqual =
      GridAxisRecord::operator==(rhs) && _dataValues == rhs._dataValues;

  return ivarsEqual;
}

int GridAxisRecordRepresentation0::getMarshalledSize() const {
  auto marshalSize = 0;

  marshalSize = GridAxisRecord::getMarshalledSize();
  marshalSize += 2; // _numberOfBytes
  marshalSize += _dataValues.size();

  return marshalSize;
}

// Copyright (c) 1995-2009 held by the author(s).  All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
//  are met:
//
//  * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the names of the Naval Postgraduate School (NPS)
//  Modeling Virtual Environments and Simulation (MOVES) Institute
// (http://www.nps.edu and http://www.MovesInstitute.org)
// nor the names of its contributors may be used to endorse or
//  promote products derived from this software without specific
// prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// AS IS AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
// COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
